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(54) Method and apparatus for remotely administered autiientication and access control services 

(57) Authentication and session management can 
be used with a system architecture that partitions func- ' 
tionality between a human interface device (HID) and a 
computational service provider such as a server. An 
authentication manager executing on a server interacts 
with the HID to validate the user when the user con- 
nects to the system via the HID. The authentication 
manager interacts with authentication modules. Each 
authentication module may be configured to authenti- 
cate a user based on a different authentication mecha- 
nism (e.g., using a smart card, using a login and 
password, using biometric data, etc.) and may be uti- 
lized In connection with one or more sessions. The 
authentication manager and authentication modules are 
also responsible for controlling access to services/ses- 
sions and may remove/revoke or augment such access. 
A session manager executing on a server manages 
services running on computers providing computational 
services (e.g., programs) on behalf of the user. The ses- 
sion manager notifies each service in a session that the 
user is attached to the system using a given desktop 
machine. A service can direct display output to the HID 
while the user is attached to the system. When a user 
detaches from the system, each of the service's execut- 
ing for the user is notified via the authentication man- 
ager and the session manager. Upon notification that 
the user is detached from the system, a service contin- 
ues to execute while stopping its display to the desktop 
machine. 
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Description 



BACKGROUND OF THE INVENTION 

5 1. FIELD OF THE INVENTION 

[0001] This Invention relates computer systems and, more specifically, to user authentication and the location man- 
agement of user sessions. 

[0002] Portions of the disclosure of this patent document contain material that is subject to copyright protection. The 
10 copyright owner has no objection to the facsimile reproduction by anyone of the patent document or the patent disclo- 
sure as it appears In the Patent and Trademark Office file or records, but otherwise reserves all copyright rights what- 
soever. Sun, Sun Microsystems, the Sun logo, Java, and all Java-based trademarks and logos are trademarks or 
registered trademarks of Sun Microsystems, Inc. in the United States and other countries. All SPARC trademarks are 
used under license and are trademarks of SPARC International, Inc. in the United States and other countries. Products 
15 bearing SPARC trademarks are based upon an architecture developed by Sun Microsystems. Inc. 

2. BACKGROUND ART 

[0003] The paradigms by which computer systems have been configured have changed over time, in earlier times, a 

20 computer consisted of a so called "mainframe" computer that was accessed by a plurality of "dumb terminals". The 
mainframe was a central station that provided computational power and data storage. A dumb terminal was a display 
device for data provided by the mainframe, and also provided a means to communicate some data to the mainframe. 
Other system paradigms followed, including the desktop computer, client/server architecture, and recently the so-called 
network computer. Using a dumb terminal paradigm, a user may switch from one terminal to another terminal. Each 

25 time a user switches a terminal, the user must be authenticated to work at new terminal. Various authentication mech- 
anisms may be utilized such as a user name and password, biometric information (e.g., fingerprint or retinal scan), a 
smart card, etc. Different types of sessions need to be supported at different terminals by varying users. The prior art 
does not provide a satisfactory means to authenticate a user and control access to available network services/sessions 
and terminals based on the authentication. 

30 [0004] A desktop computer is a self contained computing system where ail applications and data are resident on the 
desktop computer system itself. Such systems were implemented in personal computers and have spurred the use of 
computers in homes and offices. A disadvantage of desktop computers is the short lifetime of the hardware used In the 
system. Desktop computers are microprocessor driven, and as faster and more powerful microprocessors become 
available, upgrades of existing desktop systems, or purchase of new desktop systems, is required. In many offices, 

35 there are personal desktop computers distributed throughout, sometimes numbering in the thousands and tens of thou- 
sands. A disadvantage of such large systems is the lack of compatibility of applications and data on individual systems. 
Some users may have more recent versions of software applications that are not backwards compatible with older ver- 
sions of the software. The solution to this problem Is to maintain consistent software on all systems. However, the cost 
to upgrade each system and to provide licensed copies of software and software upgrades can be substantial. 

40 [0005] Client server systems are systems where central stores of data and/or applications are accessed through a 
network by personal computer clients. This provides some administrative efficiency in maintaining the shared data. 
However, the clients still have local applications and data that can present the same kinds of problems faced in the 
desktop systems already described. 

[0006] Recently, the rise of the internet has resulted in the proposed use of so-called "network computers". A network 
45 computer is a stripped down version of a personal computer with less storage space, less memory, and often less conv 
putational power. The Idea is that network computers will access data through the Internet, and only those applications 
that are needed for a particular task will be provided to the network computer. When the applications are no longer 
being used, they are not stored on the network computer. There has been some criticism of such systems as lacking 
the powerof a full desktop system, yet not being inexpensive enough to justify the reduced capability. And even though 
so the network computer is a subset of a desktop computer, the network computer may still require upgrades of hardware 
and software to maintain adequate performance levels. 

[0007] An example of a dynamic host configuration protocol is provided in RFC 2131. RFCs 1321 and 2104 contain 
examples of MD5, or message digesting. A point to point challenge host authentication protocol is contained in RFC 
1994. 

55 [0008] Prior art mechanisms provide various means to authenticate a user. One prior art mechanism is referred to as 
kerberos. The kerberos system provides authentication over a network. To authenticate a user, registration in a ker- 
beros database for each user is required. Once registered, a ticket is issued that contains an encrypted protocol mes- 
sage that provides authentication, Kerberos utilizes the ticket transparently to the user for network utilities such as NFS, 
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riogin, and rcp. A ticket may have special privileges (e.g.. for an administrator) and may expire after a specified period 
of time (e.g., 3 minutes). However, kerberos does not remove a user's session at the end of the time period, it will merely 
not allow a user to log back on once a user has disconnected. The ticket enables a user to present passwords to remote 
hosts without having to bother with remote files and login procedures. However, kerberos does not provide for access 
control features. 

[0009] Another prior art mechanism is referred to as PAM (pluggable authentication modules). PAM includes an inter- 
face library and multiple authentication service modules. The interface library is the layer implementing the application 
programming interface (API). The authentication service modules are a set of dynamically loadable objects invoked by 
the PAM API to provide a particular type of user authentication (e.g., smart card, user name and password, biometric 
data, etc.). PAM gives system administrators the flexibility of choosing any authentication service available on the sys- 
tem to perform authentication. New authentication modules can be plugged in and made available without modifying 
applications. PAM modules assume that the user being authenticated knows its identity and a password associated with 
that identity Further, the PAM system is not concerned with and assumes that a communication port (that will be used 
to communicate with a user and conduct transmissions) Is already established (e.g., the port is preconfigured for 
remote terminals and local consoles). Additionally PAM relies on statically configured users and display devices (e.g., 
a server is preconfigured for each user and terminal). Once the number of users/terminals is known, a server is precon- 
figured for each server/user statically The configurations for a user/terminal are not performed dynamically when 
requested. Further, once authenticated, PAM modules disappear and are no longer utilized. 

SUMMARY OF THE INVENTION 

[0010] Authentication and session management can be used with a system architecture that partitions functionality 
between a human interface device (HID) and a computational service provider such as a server. An authentication'man- 
ager executing on a server interacts with the HID to validate the user when the user connects to the system via the HID. 
The authentication manager interacts with authentication modules. Each authentication module may be configured to 
authenticate a user based on a different authentication mechanism (e.g.. using a smart card, using a login and pass- 
word, using biometric data, etc.) and may be utilized in connection with one or more sessions. The authentication man- 
ager and authentication modules are also responsible for controlling access to services/sessions and may 
remove/revoke or augment such access. A session manager executing on a server manages services running on com- 
puters providing computational services (e.g.. programs) on behalf of the user. The session manager notifies each 
service in a session that the user is attached to the system using a given desktop machine. A service can direct display 
output to the HID while the user is attached to the system. When a user detaches from the system, each of the sen/ice's 
executing for the user is notified via the authentication manager and the session manager. Upon notification th^t the 
user is detached from the system, a service continues to execute while stopping its display to the desktop machine, 

BRIEF DESCRIPTION OF THE DRAWINGS 

[0011] 

Figure 1 is an example of a system architecture used in one or more embodiments of the invention. 

Figure 2 illustrates authentication and session management components and their interactions according to an 
embodiment of the invention. 

Figure 3 provides a process flow for initializing a network terminal in response to a power up operation according 
to an embodiment of the invention. 

Figures 4A-4C provide a process flow according to an embodiment of the invention for initializing network terminal 
202 in response to an awaken operation. 

Figures 5A-5B provide an authentication process flow according to an embodiment of the invention. 

Figure 6 provides a challenge process flow according to an embodiment of the invention. 

Figures 7 and 8 provide examples of system architectures used in one or more embodiments of the invention. 
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DETAILED DESCRIPTION OF THE INVENTION 

[0012] A method and apparatus for remotely administered authentication and access control services is described. 
In the following description, numerous specific details are set forth in order to provide a more thorough description of 
5 the present invention. It will be apparent, however, to one skilled In the art, that the present invention may be practiced 
without these specific details. In other instances, well-known features have not been described in detail so as not to 
obscure the invention. 



[0013] Methods and apparatus are described according to one or more embodiments of the invention for authenticat- 
ing a system user and controlling access to services/sessions for a system user. In one embodiment of the invention, 
authenticating and access control are performed within a system architecture that partitions the computing functionality 
between a user's HID and a computational service provider such as a server. 
15 [0014] Figures 1 , 7, and 8 provide examples of system architectures used in one or more embodiments of the inven- 
tion. The present invention can be implemented in standard desktop computer systems such as described in Figure 1, 
or in any other computer systems, including client - server systems, network computers, or the human Interface device 
system of Figures 7 and 8. 

20 Embodiment of Computer Execution Environment (Hardware ) 

[0015] An embodiment of the invention can be implemented as computer software in the form of computer readable 
code executed on a general purpose computer such as computer ICQ illustrated in Figure 1 , or in the form of bytecode 
class files executable within a Java"^" runtime environment running on such a computer, or in the form of bytecodes run- 
25 ning on a processor (or devices enabled to process bytecodes) existing in a distributed environment (e.g., one or more 
processors on a network). A keyboard 110 and mouse 1 1 1 are coupled to a system bus 118. The keyboard and mouse 
are for introducing user input to the computer system and communicating that user input to processor 113. Other suit- 
able input devices may be used in addition to, or in place of, the mouse 111 and keyboard 110. I/O (input/output) unit 

119 coupled to system bus 118 represents such I/O elements as a printer, A/V (audio/video) I/O, etc. 

30 [0016] Computer 100 includes a video memory 114, main memory 115 and mass storage 112, are coupled to system 
bus 118 along with keyboard 110, mouse 111 and processor 113. The mass storage 112 may include both fixed and 
removable media, such as magnetic, optical or magnetic optical storage systems or any other available mass storage 
technology. Bus 118 may contain, for example, thirty-two address lines for addressing video memory 1 14 or maln.mem- 
ory 115. The system bus 118 also includes, for example, a 64-bit data bus for transferring data between and among the 

35 components, such as processor 113, main memory 115, video memory 114 and mass storage 112. Alternatively, mul- 
tiplex data/address lines may be used instead of separate data and address lines. 

[0017J In one embodiment of the invention, the processor 113 Is a microprocessor manufactured by Sun Microsys- 
tems, Inc., such as the SPARC™ microprocessor, or a microprocessor manufactured by Motorola, such as the 680X0 
processor, or a microprocessor manufactured by Intel, such as the 80X86. or Pentium processor. However, any other 

40 suitable microprocessor or microcomputer may be utilized. Main memory 1 1 5 is comprised of dynamic random access 
memory (DRAM). Video memory 1 14 is a dual-potted video random access memory. One port of the video memory 1 14 
is coupled to video amplifier 116. The video amplifier 116 is used to drive the cathode ray tube (CRT) raster monitor 
117. Video amplifier 116 is well known In the art and may be implemented by any suitable apparatus. This circuitry con- 
verts pixel data stored In video memory 1 14 to a raster signal suitable for use by monitor 117. Monitor 117 is a type of 

45 monitor suitable for displaying graphic images. 

[0018] Computer 100 may also include a communication interface 120 coupled to bus 118. Communication interface 

120 provides a two-way data communication coupling via a network link 121 to a local network 122. For example, if 
communication interface 120 is an integrated services digital network (ISDN) card or a modem, communication Inter- 
face 120 provides a data communication connection to the corresponding type of telephone line, which comprises part 

50 of network link 121. If communication interface 120 Is a local area network (LAN) card, communication interface 120 
provides a data communication connection via network link 121 to a compatible LAN. Wireless links are also possible. 
In any such implementation, communication interface 120 sends and receives electrical, electromagnetic or optical sig- 
nals which carry digital data streams representing various types of information. 

[0019] Network link 121 typically provides data communication through one or more networks to other data devices. 
55 For example, network link 121 may provide a connection through local network 122 to local server computer 123 or to 
data equipment operated by an Internet Service Provider (ISP) 124, ISP 124 in turn provides data communication serv- 
ices through the world wide packet data communication network now commonly referred to as the "Internet" 125. Local 
network 122 and Internet 125 both use electrical, electromagnetic or optical signals which carry digital data streams. 
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The signals through the various networks and the signals on network link 121 and through connmunication interface 
120, which carry the digital data to and from computer 100, are exemplary forms of cannier waves transporting the infor- 
P mation. 

[0020] Computer 100 can send messages and receive data, including program code, through the network(s). network 
5 link 121, and communication Interface 120. In the Internet example, remote server computer 126 might transmit a 
requested code for an application program through Internet 125, ISP 124, local network 122 and communication inter- 
face 120. In accord with the invention, one such downloaded application is the apparatus for selecting attachments 
described herein. 

[0021] The received code may be executed by processor 1 13 as it is received, and/or stored in mass storage 1 12, or 
10 other non-volatile storage for later execution. In this manner, computer 100 may obtain application code in the form of 
a carrier wave. 

[0022] Application code may be embodied in any form of computer program product. A computer program product 
comprises a medium configured to store or transport computer readable code, or in which computer readable code may 
be embedded. Some examples of computer program products are CD-ROM disks. ROM cards, floppy disks, magnetic 
15 tapes, computer hard drives, servers on a network, and carrier waves. 

[0023] The computer systems described above are for purposes of example only An embodiment of the invention 
may be implemented in any type of computer system or programming or processing environment. 
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Human Int erface Device Computer System 



[0024] The invention also has application to a computer systems where the data to be displayed is provided through 
a network. The network can be a local area network, a wide area network, the internet, world wide web, or any other 
suitable network configuration. One embodiment of the invention is used in computer system configuration referred to 
herein as a human interface device computer system. 

25 [0025] In this system the functionality of the system Is partitioned between a display and input device, and data 
sources or services. The display and input device is a human interface device (HID). The partitioning of this system is 
such that state and computation functions have been removed from the HID and reside on data sources or services. In 
one embodiment of the Invention, one or more services communicate with one or more HIDs through some intercon- 
nect fabric, such as a network. An example of such a system is illustrated in Figure 7. Referring to Figure 7; the system 

30 consists of computational service providers 700 communicating data through Interconnect fabric 701 to HIDs 702. 

[0026] Computational Service Providers - In the HID system, the computational power and state maintenance is found 
In the service providers, or services. The services are not tied to a specific computer, but may be distributed over one 
or more traditional desktop systems such as described in connection with Figure 1 . or with traditional servers. One com- 
puter may have one or more services, or a service may be implemented by one or more computers. The service pro- 

35 vides computation, state, and data to the HIDs and the service is under the control of a common authority or manager. 
In Figure 7, the services are found on computers 710. 711, 712, 713, and 714. 

[0027] Examples of services include Java™ program execution service, XI 1/Unix services, archived video services, 
Windows NT service, and others. A service herein is a process that provides output data and responds to user requests 
and Input. 

40 [0028] Interconnection Fabrjc - In the invention, the Interconnection fabric is any of multiple suitable communication 
paths for carrying data between the services and the HIDs. In one embodiment the interconnect fabric is a local area 
network implemented as an Ethernet network. Any other local network may also be utilized. The invention also contem- 
plates the use of wide area networks, the internet, the world wide web. and others. The Interconnect fabric may be 
implemented with a physical medium such as a wire or fiber optic cable, or It may be implemented In a wireless envi- 

45 ronment. 

[0029] HIDs - The HID is the means by which users access the computational services provided by the servers or 
services, and as such the HID may also be referred to as a client or user. workstation or terminal. Figure 7 illustrates 
HIDs 721, 722, and 723. A HID consists of a display 726, a keyboard 724. mouse 725, and audio speakers 727. The 
HID Includes the electronics need to interface these devices to the Interconnection fabric and to transmit to and receive 

50 data from the services. 

[0030] A block diagram of the HID is illustrated In Figure 8. The components of the HID are coupled internally to a PCI 
bus 812. A network control block 802 communicates to the interconnect fabric, such as an ethernet, through line 814. 
An audio codec 803 receives audio data on interface 816 and is coupled to block 802, USB data communication is pro- 
vided on lines 813 to USB controller 801 . 
55 [0031] An embedded processor 804 may be. for example, a Sparc2ep 804 with coupled flash memory 805 and DRAM 
806. The USB controller 801. network controller 802 and embedded processor 804 are all coupled to the PCI bus 812. 
Also coupled to the PCI 812 is the video controller 809. The video controller 809 may be for example, and ATI Rage128 
frame buffer controller (or any other suitable controller) that provides SVGA output on line 815. NTSC or PAL data Is 
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provided Into the video controller through video decoder 810. A smart card interface 808 nnay also be coupled to the 

video controller 809. 

[0032] Alternatively, the HID can be innplemented using a single chip solution including the necessary processing 
capability 

5 [0033] This architecture or systenn is described In greater detail in U.S. Patent Application Serial No. 09/063,335. 
assigned to the present assignee, filed April 20. 1998. entitled "Method and Apparatus for Providing a Virtual Desktop 
System Architecture" which Is hereby fully incorporated by reference. 

[0034] The computer systems described above are for purposes of example only An embodiment of the invention 
may be implemented in any type of computer system or programming or processing environment. 

10 [0035] In one or more embodiments of the invention, authentication and session management components are con- 
figured to authenticate users and control access to services/sessions. A session Is a persistent representation of a 
related set of one or more services executing on behalf of a user. Embodiments of the invention authenticate a user and 
relocate a user's session based on the current location of the user without requiring a service within a session to be 
configured to perform user validation and relocation. One or more embodiments of the Invention authenticate the user 

15 once for all of the user's services. Other embodiments of the invention may require reauthentication or a new authenti- 
cation depending on the service utilized. Using embodiments of the invention, services are directed to the HID (or other 
terminal device) that a user is currently using. It is not necessary for the user to login to each service and establish a 
new connection for a specific HID. Using embodiments of the invention, the use of a particular service may also be ter- 
minated if desired. For example, after a designated time period, a user's authentication may no longer be valid and such 

20 Invalidity may act to terminate a session. Alternatively, a user may be requested to reauthenticate themselves every so 
often to ensure only authorized users are permitted access. Should a reauthentication attempt fail, a session may be 
terminated immediately. 

[0036] According to embodiments of the invention, authentication is a one-way authentication which improves the 
manageability and scalability of authentication. There is no need to exchange keys and avoids the need to perform key 

25 lookups in a central database, 

[0037] Figure 2 illustrates authentication and session management components and their interactions according to 
an embodiment of the invention. Network terminal 202 is a human interface device (HID) (e.g., HIDs 821. 822 and 823). 
An HID has, as examples of its functions, the task of displaying output of services to a user and obtaining input to serv- 
ices from the user. Network terminal 202 has the ability to respond to a command (e.g., display command) received 

30 from, for example, a software program (e.g.. services 230-238, authentication manager 204 and session manager 206) 
executing on a computational service provider (e.g., computers 710, 711 . 712. 713. and 714). The input received from 
a user is fonwarded to, for example, a service that is fulfilling a user request. 

[0038] More than one server can execute the services that comprise a session. For example, in session 208, service 
230 is executing on server 210, services 232 and 234 are executing on server 212 and services 236 and 238 are exe- 
35 outing on server 214. 

[0039] A user may access a system (e.g., a server, a session, a service and a network terminal) by initiating a login 
or other authentication mechanism (e.g., smart card, biometric data, etc.). A separate authentication module 240 may 
be utilized for each authentication mechanism. During login, the user is validated by an authentication module 240. The 
authentication modules 240 communicate with authentication manager 240 where a user may be associated with a par- 
40 ticular session. Various techniques can be used to allow the user to initiate a login. For example, the user can initiate a 
login by pressing a key on network terminal 202. Further, a terminal 202 may have screen display icons that allow a 
user to determine the progress of the authentication process. 

[0040] In one embodiment of the invention, a user accesses the system by inserting a smart card in a card reader 
(e.g., card reader 216) attached to network terminal 202. A smart card is a card that is capable of storing information 
45 such as In a magnetic strip or memory of the smart card. The smart card can store user information such as a user's 
identification (i.e., user ID such as a 64-bit number) and a secret code (e.g.. a 128-bit random number) that is transmit- 
ted to network terminal 202. The secret code is used during authentication by a smart card authentication module, for 
example. 

[0041] Network terminal 202 is aware of (or can obtain) its interconnection network address and the address of 
so authentication manager 204, When a user initiates the login, network terminal 202 initiates communication with authen- 
tication manager 204 to begin authentication. Authentication manager 204 is a program active (e.g., executing) on a 
computational service provider connected to network terminal 202 via an interconnection network such as a local area 
network (LAN), for example. It should be apparent, however, that network terminal 202 can be connected to authenti- 
cation manager 204 using other interconnection network technologies such as a fiber channel loop or point-to-point 
55 cables. Network terminal 202 sends a startup request to authentication manager 204 that includes a unique identifier 
that may correspond to a user. Such an identifier may originate from a token (a particular message or bit pattern that 
signifies permission to transmit information) or a pseudo token. For example, tokens may be encoded into smart cards 
and when a smart card is inserted in a card reader at a terminal, the token is transmitted from the terminal 202. Alter- 
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natively, a token may be created by a fingerprint reader or other external device. If a smart card is not inserted, or a 
^ token is not presented at terminal 202. terminal 202 may construct a "pseudo token" and transmit the pseudo token to 
y authentication manager 204. A pseudo token may be identified by the type associated with it (e.g., "pseudo") and a net- 
work Interface address such as an ethernet address or a media access controller (MAC) address. 
5 [0042] To initiate a connection, a network terminal 202 may be booted up. Once booted, terminal 202 may utilize a 
dynamic host configuration protocol (DHCP) to obtain application parameters such as the Internet protocol address. 
Terminal 202 then establishes a connection with authentication manager 204 (e.g., using TCP). To establish a connec- 
tion, terminal 202 may send a message or present a token to the authentication manager 204. Authentication manager 
204 then determines whether it wants to take responsibility for this particular terminal/user. In one or more embodi- 
10 ments, authentication manager 204 presents the message (with the token) to one or more authentication modules 240. 
[0043] Authentication modules 240 each have the option of accepting or declining responsibility for a particular con- 
nection. Authentication modules 240 may base their decision on other available system resources or settings (e.g.. from 
services 230-238. external databases, etc.). In one or more embodiments, an authentication module 240 can be con- 
figured to accept all users all of the time, to only accept connections with smart cards, or to only accept users with 
15 pseudo tokens, for example. 

[0044] In one or more embodiments, authentication modules 240 may be cascaded and a message may pass from 
one module to another module until responsibility is accepted. Thus, when an authentication module 240 declines 
responsibility for a particular connection, the message may be passed onto another authentication module 240. Mod- 
ules 240 may be ordered such that the first time responsibility is claimed, all "lower" modules do not apply. Alternatively, 
20 modules 240 may be stacked and multiple modules may be utilized or required in one connection. If all modules decline 
responsibility, access may be deified. If a module 240 decides to accept responsibility various generic services may be 
provided to modules 240 by authentication manager 204. For example, authentication manager 204 may provide 
authentication module 240 with a start session service (a procedure that ensures a session is started (see further 
description below)). Additionally the module 240 has the option of further communicating with terminal 202. For exam- 
25 pie, module 240 may challenge the user using a challenge-response routine or request a secondary password. 

[0045] Authentication modules may be structured for any mechanism that verifies the identity of the user to the sys- 
tem. A key or password known only to the user, or biometrics information can be used to authenticate the user. For 
example, one authentication module may be utilized to authenticate a user based on a smart card while another 
authentication module may be utilized to authenticate a user based on a key or password or biometrics information. 
30 [0046] In one or more embodiments of the invention, authentication is performed by verifying a personal identification 
number (PIN) entered by the user at network terminal 202 by an authentication module 240. An authentication module 
240 sends a command (i.e., a challenge command) to initiate entry of the user's PIN'at network terminal 202. The user 
entry is packaged by network terminal 202 and transmitted to authentication module 240 (i.e., a challenge response). 
[0047] Authentication module 240 verifies the challenge response with user information retained in authentication 
35 database 218. for example, information supplied by the user and information that is generated during authentication. 
When the user is authenticated, the user eventually be given access to a session (e.g., session 208). Through the user 
authentication process, authentication modules are able to establish a communication port through which future trans- 
missions will be conducted with terminal 202. Thus, authentication modules 240 are concerned with both the wiring to 
a terminal to establish a port and authenticating a user utilizing that port. 
40 [0048] In one or more embodiments, two authentication modules may be utilized. In such an embodiment, when a 
token or smart card is inserted at terminal 202, terminal 202 sends a message to authentication manager 204, Authen- 
tication manager 204 presents the message to the first authentication module 240. The first authentication module 240 
looks up the token in a database to determine if the token is registered with the system. If not (i.e., the first authentica- 
tion module does not want to accept responsibility for the token/message), the first authentication module passes the 
45 token/message onto a second authentication module. The second authentication module may be configured to accept 
all tokens/messages. Once the token is received, the second authentication module may initiate a registration session 
and inform the session manager to connect the session to the terminal issuing the request. The registration application 
presents a form interface to the user where information regarding the user may be obtained (e.g., a username and 
password or biometric data). Once the information is received, the information about the user and the token may be 
50 stored in a database. Consequently, a token may be bound to a particular user. The registration application may then 
terminate. Thus, the next time a token Is presented to the first authentication module, the token is present and regis- 
tered with the system so that the first authentication manager may take responsibility for the token/message. Using this 
embodiment, users update a registration database instead of relying on an administrator to manually update informa- 
tion each time a new user is added to a system. Thus, authentication manager 204 is responsible for passing messages 
55 onto authentication modules 240, for denying or allowing access to a session, and if allowing access, determining what 
type of session to present to terminal 202. 

[0049] In one or more embodiments of the invention, once authenticated, the authentication modules may remain 
active and ensure that the authentication maintains a proper state. For example, authentication may be time sensitive 
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(e.g., from 9 A.M. to 5 P.M.) and once the specified tinne has expired, an authentication module 240 may revoke the 
authentication and a session may be terminated. Alternatively, an authentication module 240 may require reauthentica- 
tlon from a user at random times. For example, If a user is at a terminal 202 that requires payment every 10 minutes, 
an authentication module 240 may debit a cash card every 10 minutes until the cash card is empty at which point a ses- 
5 sion may be removed/revoked from display on terminal 202. In another use, a teacher in a classroom may validate stu- 
dent's terminals for one hour to view a preconfigured set of internet sites. After an hour, authentication modules 240 
may remove/revoke each student's display of the session. 

[0050] If the expected result is received from the user (i.e., authentication module 240 has authenticated a user), 
authentication module 240 informs authentication manager 204 of the authentication. Authentication manager 204 or 

10 authentication module 240 may then use a start session service to ensure a session is currently running. Once a ses- 
sion is established, terminal 202 is connected to the session. To establish a connection to a session, authentication 
manager 204 notifies session manager 206 (via a connect message) that the user has logged into the system on net- 
work terminal 202. Session information contained In authentication database 218 may be used to Identify the server, 
port and session identifier (ID) for session manager 206. Session manager 206 is a program that is active on a compu- 

15 tational service provider and is connected to authentication manager 204 and network terminal 202 via an Interconnec- 
tion network, for example. Thus, as described, authentication manager 204 sends a message to session manager 206 
using session manager 206's server and port Information contained in authentication database 218, for example. As a 
result, authentication manager 204 dynamically configures a network terminal for a particular service (e.g., services 
230-238). In one or more embodiments of the invention, authentication modules 240 may annotate a session based on 

20 the authentication and a behavior can be modified based on the annotation. For example, a module 240 may annotate 
a session such that a user is authenticated based on a fingerprint and subsequent authentication modules can use that 
annotation. 

[0051] In response to the connect message from authentication manager 204, session manager 206 notifies the serv- 
ices in the user's current session (i.e., the services In session 208) that the user Is attached to network terminal 202. 

25 That Is, session manager 206 sends a connect message to services 230-238 to direct output to network terminal 202. 
Session manager 206 ensures that services that are considered to be required services of the session are executing. 
If not, session manager 206 causes them to be initiated. The user can interact with services 230-238 within a session 
(e.g., session 208). Network terminal 202 Is connected to servers 210, 212 and 214 (and services 230-238) via an inter- 
connection network such as a local area network or other Interconnection technology. The user can also start new serv- 

30 ices or terminate existing services. For example, if a login service/session (e.g., a service that prompts a user for a 
login) has been running for a certain period of time without a user entering the username and password (e.g., it is anno- 
tated as idle for a certain period of time), the login service may be terminated. Once a user desires to enter a username 
and password (e.g., by depressing a key on the keyboard), a new login session may be initiated and annotated as not 
Idle. 

35 [0052] The user can detach from the system by removing the card from card reader 216. Other mechanisms to 
express a disconnect can also be used with the invention (e.g.. a "sign-off button on network terminal 202). Services 
230-238 can continue to run even after the user removes the card from card reader 216. That is, a user's associated 
session(s) and the services that comprise a session can continue in existence during the period that a user is unat- 
tached (e.g., logged off ) from the system. When the user removes the card from card reader 216, network terminal 202 

40 notifies authentication manager 204 (e.g., via a disconnect message) which notifies session manager 206 (e.g., via a 
disconnect message). Session manager 206 notifies services 230-238 (e.g., via a disconnect message) which termi- 
nate their transmission of display commands to network terminal 202. Services 230-238 continue execution, however, 
during the time that the user is not logged onto a network terminal. The user can log back in using a network terminal 
such as network terminal 202, connect to session 208 and Interact with services 230-238. 

45 [0053] While Figure 2 depicts a single Instance of each, it should be apparent that there can be multiple instances of 
network terminal 202, authentication manager 204, authentication modules 240, and session 208. For example, there 
can be more than one instance of authentication manager 204 servicing network terminal 202 or multiple instances of 
network terminal 202. Authentication manager 204 instances can be organized in a hierarchy according to the topology 
of the network or they can be globally available, for example. 

50 [0054] Having more than one instance of the authentication manager improves the scalability of the system since it 
is possible to add (or remove) instances of authentication manager 204 based on the current load (e.g.. the number of 
users). Further, reliability is improved since redundant instances of authentication manager 204 can be deployed. 
[0055] Similarly, there can be a multiplicity of session manager 206 instances. Like authentication manager 204, mul- 
tiple instances of session manager 206 can increase the scalability and reliability of the system. 



S^ggjpn Manager 

[0056] Session manager 206 maintains session database 220 that contains mappings between users, sessions, and 
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services. Session manager 206 manages the services that comprise each session manage^^session manager 206. 
For example, session manager 206 maintains session 208 and services 230-238 within session 208. 
[0057] To access a computational service provider, an account is first set up or enabled for a user. For example, to 
enable a user according to one embodiment of the invention, the user is given a userlD. a PIN and a smart card that 
stores the userlD and secret code. In addition, a session is created for the user. As described below, a session can have 
none or more required services. It may be necessary to initiate some of the required services when the session is cre- 
ated. Once a service is initiated, it continues to be active regardless of whether the user is connected to the system. 
The balance of required services can be initiated when the user first logs in. 

[0058] A user is not limited to one session. There can be multiple sessions associated with a user at any given time 
Session database 220 contains records that identify the session(s) and service(s) within a session that are associated 
with a user. An enabled user can be removed from the system (e.g.. when an authentication module 240 determines 
that a user is no longer authentic (e.g.. time limit has expired)). When a user is removed from the system, ail of the 
user's associated sessions are removed from the system and from session database 220. Services associated with the 
user's sessions are stopped as well. 

[0059] Once a user is enabled to use a system, the user can log onto the system via network terminal 202. When 
session manager 206 is notified by authentication manager 204 that the user is connected to network terminal 202. ses- 
sion manager 206 notifies the user's session (i.e., the services that comprise a session). Session manager 206 corisults 
session database 220 to identify and notify the session's services. For example, session database 220 includes infor- 
mation that identifies session 208 and services 230-238 that are included in session 208. 

[0060] In one or more embodiments, session database 220 may include currently active sessions and associated 
tokens. Consequently, if authentication manager 204 dies or is explidtly shut down, all sessions may be disconnected 
However, once authentication manager 204 is started back up. session database 220 may be utilized to reconstruct 
connections between sessions and the associated tokens. In one or more embodiments, an additional database may 
be utilized that contains a mapping between a user Identity tokens, sessions, and associated permissions. Such a data- 
base provides information regarding whether a token is allowed access or not to a particular session and what type of 
session or particular services may be utilized by a particular token. Thus, varying tokens may have different levels of 
access associated with the token. For example, one token may provide the ability to use an internet browser application 
while another token may provide unlimited access to all resources on the network, and another token may provide 
access to a certain desktop organization or architecture. 

[0061] In one or more embodiments, a different database type may exist for each authentication module 240. Alter- 
natively one module 240 may utilize several database types. Such databases may be in a format consisting of key- 
value pairs, a table, or tabular. 

[0062] In one or more embodiments, session database 220 contains permanent session records and dynamic ses- 
sion records that identify sessions and the services associated with a session; Session database 220 can be one or 
more databases or data stores. For example, permanent session records can be stored in a configuration file while 
dynamic session records can be stored in memory in a database system. A permanent session record contains config- 
uration information for a user and is typically created for a user at the time the user is enabled to use the system for 
example. A dynamic session record identifies those services that are associated with a user. Dynamic session records 
Identify the required services that are associated with a user session In a permanent session record as well as currently 
active services. The following contains a format for a permanent session record according to an embodiment of the 
invention: 



sessiontD servicelD serviceHost servicePort isLazy 

[0063] The sessionID field uniquely identifies the session that contains the required service(s). The servicelD field 
uniquely identifies a service associated with the session identified by sessionID. The serviceHost and servicePort fields 
Identify the server on which a service is running and the port on the server by which a service can receive communica- 
tions. The isLazy field identifies the manner in which a service is initiated. For example, isLazy can specify that the serv- 
ice is to be started immediately upon the creation of a session, or that the service is to be started when the user first 
accesses the system. There may be multiple occurrences of the servicelD. serviceHost. servicePort and isLazy fields 
each occurrence identifying a required service associated with the session identified by sessionID. 
[0064] The dynamic session record identifies the required services for the session and those services that are cur- 
rently executing in the session. A session's required services are retrieved from the permanent session record, for 
example, A dynamic session record can identify zero or more services (required or otherwise) that are currently execut- 
ing on behalf of a user. 

[0065] The fields that are used to store information about a service in a dynamic session record depends on whether 
the service Is a required service or a service. A required service that is currently active is also a current service. The 
format of a dynamic session record that identifies a session's required services is the same as the permanent session 
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record format. The following identifies the format for a record associated with a currently executing service according to 
an embodiment of the invention: 



sessionLink TCPSocketfd requiredServiceLink serv'icelD 

5 

[0066] The sessionLink field identifies the service's session. An open connection, or pipe, is established between ses- 
sion manager 206 and a currently executing service in a session. The open connection can be used to notify either ses- 
sion manager 206 or the service that the other has abnormally, or otherwise, terminated. In one embodiment of the 
invention, the open connection is a TCP socket connection which is identified by the TCPSocketfd field. However, it 
10 should be apparent that any form of reliable connection technology that could provide a notification that a connection is 
disabled or disappears could be used with embodiments of the invention. 

[0067] The service has an identifier that is stored in the servicelD field. A currently running service can be linked to a 
required service. A link to a required service is identified by the requiredServiceLink. If there is no link to a required 
service, the requiredServiceLink is null. 
15 [0068] The dynamic session record can also be used to store information about a connection to a network terminal 
(e.g., network terminal 202). The following contains the fields that identify the connection according to an embodiment 
of the Invention: 



sessionLink Status IPAddress 

20 

[0069] Multiple sessions can be associated with a user. The sessionLink field identifies the session to which the user 
attached to network terminal 202 is currently linked. The sessionLink can have as its value the sessionID value, for 
example. The status field identifies the connection status (i.e., connected or disconnected) of network terminal 202 to 
the session. The IPAddress field contains the interconnection network address of network terminal 202. An IP address 
25 is used in one or more embodiments of the invention. However, it should be apparent that alternative interconnection 
technologies may use alternate addressing schemes. For example, an asynchronous transfer mode (ATM) network 
might use a thirteen digit switch prefix/end point identifier. 

[0070] This information can be used by session manager 206 to send a status message to network terminal 202. If 
network terminal 202 does not respond within a certain period of time, session manager 206 assumes that network ter- 
30 minal 202 is no longer in use by the user and sends a disconnect message to each of the services in the session. 

[0071] Other information of which session manager 206 is aware include a list of the open connections (e.g., services 
having an open TCPsocketfd) to services and a mapping between open connections and sessions and the services 
within a session. This information can be compiled from the session records, for example. 

[0072] The information available to session manager 206 can be used to locate a session. For example, given a serv- 
35 ice, it is possible to find a session that contains the service and/or the services that are contained within a session. Fur- 
ther, it Is possible to locate a session that is associated with a given user or instance of network terminal 202 whether 
or not it is currently executing, for example. 



Service Initiation 

40 

[0073] When session manager 206 receives a message from authentication manager 204 that a user is connected 
to network terminal 202 (and has been authenticated by an authentication module 240), session manager 206 initiates 
those required services that are not currently active. Session manager 206 further notifies the currently active services 
to direct input/output (I/O) to network terminal 202. I/O can be expressed using a command protocol used to communi- 

45 cats with network terminal 202 and its peripheral devices. 

[0074] To initiate a service, session manager 206 accesses the server on which the service is to execute to start the 
service. For example, session manager 206 sends a request to a well-known port on the server and passes the ses- 
sionHost, sessionPort and sessionID for session manager 206. The server connects to network terminal 202 that Is 
attached to the service and uses the server's native authentication and permissions to allow the user to access the 

50 server. For example, in a UNIX operating environment, a UNIX service could start with a "CDE Login" screen displayed 
at network terminal 202 to authenticate the user and ensure that the user wishes to connect to the service. 
[0075] For session manager 206 to start a service on a server, it is given the privileges needed to start the service. It 
may be undesirable to give session manager 206 these privileges. Further, in current networking ienvironments, servers 
may be running different operating environments. In this case, session manager 206 must be aware of each operating 

55 environment's procedures for initiafing a service. 

[0076] Alternatively, a session-aware application running on the server can perform the initiation and register the serv- 
ice with session manager 206. In this case, it is not necessary for session manager 206 to have the needed privileges. 
Further, session manger 206 does not have to implement a centralized model for initiating services on multiple operat- 
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ing environments. The responsibility foM?iitiating services is left to the session-aware applSons that are running in 
the different operating environments. A session-aware server application has knowledge of session manager 206 (e.g., 
has the sessionlD. sessionHost and sessionPort of session manager 206) and its interfaces (e.g., message formats). ' 
[0077] The session-aware server application can initiate a service in response to a request received from session 
manager 206. Session manager 206 sends an initiate message to the server application that possesses the permission 
to start services in the server's operating environment. The server application initiates the service for session manager 
206 and responds to session manager 206 with a valid sessionlD. On the UNIX and NT systems, for example, the ses- 
sionlD can be made available in the operating environment. Services such as video windows might start in this manner, 
for example. 

[0078] Alternatively, the session-aware application can contact a service to obtain its permission in the form of a cryp- 
tographically signed authorization. The server application can transmit the sessionlD and the signed authorization to 
session manager 206. If the session-aware application contacts session manger 206 without an authorization but with 
a description of the service, session manager 206 could request approval from network terminal 202 to ensure that the 
user authorized the service. If the user responds affirmatively, the service is added to the session. In one or more 
embodiments of the invention, authentication modules 240 are responsible for controlling access to one or more ses- 
sions. Consequently, an authentication module 240 may authenticate a user for a particular session or multiple ses- 
sions depending on the privileges specified in the authentication module 240. 

Session Manager Messages 

[0079] Session manager 206 receives and generates messages to manage the services within a session. Techniques 
other than those described herein can be used for initiating services. If session manager 206 initiates a service, it sends 
an initiate message to the server (or session-aware server application). Session manager 206 can generate an initiate 
message to start required services identified in session database 220, for example. As another example, session man- 
ager 206 can send an initiate message to. re-activate a required service that it has determined (e.g.. via an open TCP 
connection between session manager 206 and the service) has terminated. 

[0080] Session manager 206 receives a connect message when a user of network terminal 202 successfully attaches 
to the system. In response to the connect message, session manager 206 verifies that all of the required services are 
started, and starts those that are not running. Session manager 206 sends a message (e.g., a connect message) to the 
services in the session to direct I/O to network terminal 206. 

[0081] In one or more embodiments, session manager 206 monitors the stabs of sessions and can determine when 
there are no longer any active sessions. For example, If an embodiment utilizes two authentication modules (as 
described above), session manager 206 detects when the registration application/session is finished since no sessions 
are active. Session manager 206 transmits a message to authentication manager 204 indicating that the number of ses- 
sions are empty. Authentication manager 204 determines whether to terminate the connection with the terminal. A 
determination to terminate the connection causes terminal 202 to reevaluate the state of the tokens that have been pre- 
sented to terminal 202. Terminal 202 may then resubmit any currently presented tokens to authentication manager 204 
to start the process over again. 

[0082] In one or more embodiments, when a disconnect message is received, session manager 206 sends a discon- 
nect message to each one of the services in the session directing them to terminate sending I/O to network terminal 

202. 

[0083] Session manager 206 can send status messages to network terminal 206 periodically to ensure that network 
terminal 202 is still connected. For example, session manager 206 can examine session database 220's dynamic ses- 
sion records to identify each session that Is currently connected to a network terminal. That is, session manager 206 
can examine the status field associated with a network terminal In a dynamic session record in session database 220. 
Session manager 206 sends a status request (e.g., a "ping") to each network terminal that is connected with a session. 
If an answer is not received from network terminal 202 within a certain period of lime (e.g.. 20 seconds) for a particular 
session, session manager 206 assumes that the session Is disabled and it sends a disconnect message to each serv- 
ice in the session Instructing them to terminate display functions. In one or more embodiments, a UDP protocol is uti- 
lized to transmit a status request and receive a response. 

[0084] Network terminal 202 responds to the stabs (e.g.. ping) request from session manager 206 with either a "Card 
In" or "Card Out" status. If a "Card Out" status is received from network terminal 202. session manager 206 sends a 
disconnect message to each of the session's services. 

[0085] If the "Card In" status is sent in response to a status request network terminal 202 also indicates the number 
of insertions of the card in card reader 216. the number of seconds since a card insertion, and the cardlD. The cardID 
is. for example, the value of sessionlD for the user's session. Session manager 206 retains at least the last status Infor- 
mation received from network terminal 202 to compare the new status information against the previous status informa- 
tion. If, for example, the number of Insertions or the number of seconds for insertion differs from the last status 
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information, session manager 206 considers the session to be disabled. In this case, session manager 206 sends a dis- 
connect message to the session's services. 

[0086] In one or more embodiments of the invention, session manager 206 does not ping terminals. In such an 
embodiment a TCP/IP protocol may be utilized (a protocol that is more reliable than UDP) to transmit messages 

5 between terminal 202 and session manager 206. Due to the reliability of the TCP/IP protocol (transmission control pro- 
tocol/internet protocol), a message sent from either terminal 202 or session manager 206 only needs to be sent once. 
As long as the connection between the terminal 202 and session manager 206 remains active, the presence or 
absence of a token (e.g., when a card is removed or a user logs out) may cause a "Token Inserted" message (similar 
to a "Card In" message) or "Token Remove" message (similar to a "Card Out" message) to be transmitted from terminal 

10 202 to session manager 206. Once such a message is transmitted to session manager 206, session manager 206 may 
transmit a disconnect message to the session's services. 

[0087] In one or more embodiments of the Invention, authentication modules 240 may remain active and monitor the 
authentication state of a user or terminal. For example, when a card is removed, a smart card authentication module 
may remove or revoke access to sessions associated with the card. Further, as described above, authentication mod- 
15 ules may periodically reauthenticate a user/terminal (e.g.. by requesting a user name and password again, by request- 
ing a fingerprint again, etc.). 

[0088] When a service is started by, for example, a session-aware server application, a service connect message is 
sent to session manager 206. If the service has the proper authorization, session manager 206 adds the service to the 
list of services for the session and sends a message to the service to direct I/O to network terminal 202, 

20 

Authentication Manager 

[0089] The authentication manager and authentication modules are responsible for ensuring the legitimacy of a user 
and associating/controlling access to a sesslon(s) for a user. During the Initialization process (which is described in 
25 more detail below), a port to communicate with a terminal is established and an authentication exchange takes place 
to authenticate the user in one embodiment of the invention. Authentication can Include any mechanism that verifies the 
identify of the user to the system. For example, a key password can be entered or biometrics data can be collected to 
authenticate the user. 

[0090] Authentication database 218 contains user and session information that can be accessed by authentication 
30 manager 204 or authentication modules 240. In one embodiment of the Invention, the format of a record contained In 
authentication database 218 is as follows: 

userlD secret PIN sessionHost sessionPort sesslonID 

35 [0091] The userlD and secret fields contain the same values as those stored In a user's smart card. The userlD and 
secret values are typically established when the user is enabled to use the system, for example. In one embodiment of 
the Invention, the secret field contains a 128-blt value. The PIN field is the personal Identification number (PIN) that is 
known to the user and requested by an authentication module 240 during authentication. The userlD. secret and PIN 
values are used to authenticate a user. Authentication database 218 could contain other information such as a pass- 

40 word or biometrics data, if they were used to authenticate a user. Alternatively, authentication modules 240 may store 
the information instead of authentication database 218. 

[0092] The sessionHost field Identifies the computational service provider (e.g., a server) that is executing session 
manager 206 that Is managing the user's current session. The sessionPort field Identifies the port (as established by an 
authentication module 240) for communicating with session manager 206. The sessionID field contains a unique iden- 
45 tifier for session manager 206. If authentication is successful, the sessionHost, sessionPort and sessionID) fields are 
used to notify session manager 206 of the user's location at the network terminal 202. Further, authentication modules 
240 are responsible for establishing and setting the port in authentication database 218. 

[0093] In an embodiment of the invention, a challenge mechanism may be used to authenticate a user. (Figure 6 pro- 
vides a challenge process flow according to an embodiment of the invention.) Authentication module 240 sends a chal- 
50 lenge to network terminal 202 to verify the authenticity of the user. Network terminal 202 prepares the challenge 
response, and returns it to authentication module 240. If the response to the challenge is as expected, the user is ver- 
ified to authentication module 240. Authentication module 240 communicates with authentication manager 204 that 
communicates with session manager 206. 

[0094] Figures 5A-AB provide an authentication process flow according to an embodiment of the invention. The 
55 authentication process can be repeated more than once until authentication is successful or the number of repetitions, 
or rounds, exceeds a certain number. At step 502, an identifier that represents the number of the authentication round 
is initialized to zero. At step 504, a random number is generated that is used as the challenge number. At step 506, 
authentication module 240 sends an N.AUTHENTICATE command to network terminal 202 as well as a packet of infor- 
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mation for the authentication process 

[0095] In one embodiment of the invention, the following information is sent in conjunction with the 
N_ AUTHENTICATE command: 



code identifier length valueSize value 



[0096] The code field Identifies the type of information contained in the information packet. For example, a value of 
"1" indicates that the information packet contains a challenge. The identifier field contains the value (i.e.. the round indi- 
cator) that was generated at step 502. The length field identifies the length of the information packet. The value field 
contains the random number, or value of the challenge, generated in step 504. The valueSize identifies the size of the 
value field (e.g.. 128 bits). 

[0097] In one or more embodiments, authentication messages are transmitted as key-value pairs in an ASCII string 
format with each key-value pair separated by spaces and a carriage return signifying that there are no more key-value 
pairs. A key-value pair may be transmitted as a key (field name) followed by the equals sign ("=") followed by the value 
for that key (or field). For example, a key-value pair indicating a pseudo token may be "TYPE=pseudo" wherein the key 
is "TYPE" and the value for the key is "pseudo". Alternatively, the value may be javacard for a javacard token or mondex 
for a mondex card token. Such key-value pairs may be followed by a token identifier such as "ID=TOKENID343234234" 
wherein the key is "ID" and the value for the key is "TOKENID343234234". In one embodiment, if a space, equals sign 
("="), or a new line character needs to be transmitted, it is preceded by a backslash (T) followed by three base-8 digits 
that represents the character is ASCII. 

[0098] At step 508. authentication module 240 sends rendering commands to network terminal 202 prompting the 
user for the user's PIN. At step 510. authentication module 240 waits for a response from network terminal 202 or a 
timeout. 

[0099] If a timeout is detected at step 510. processing continues at step 514 to determine whether the maximum 
number of rounds has been exceeded. If not. processing continues at step 518 to increment the identifier and process- 
ing continues at step 504 to begin a new authentication round. If it Is determined, at step 514. that the maximum number 
of rounds has occurred, processing continues at step 516 wherein authentication module 240 sends rendering com- 
mands to network terminal 202 Indicating a failure and the authentication process ends. Rendering commands can be. 
for example, part of a command protocol used to communicate with network terminal 202 and its peripheral devices. 
[0100] A challenge routine includes commands sent by authentication module 240 to network terminal 202 to capture 
the PIN entry by the user and generates a response. Network terminal 202 generates a response value that Is the out- 
put of a hash function (i.e.. a hash value or challenge response) from an Input including the user's PIN. the value of the 
identifier, the value of the secret stored in the user's smart card and the value of the challenge (e.g., the random number 
generated In step 504). 

[0101] A hash function can take variable-length input and convert it to a fixed-length output (a hash value). One exam- 
ple of a hash function takes the input and returns a byte consisting of the exclusive-or (XOR) of all the input bytes. There 
- are many other examples of hash functions that can used with embodiments of the invention. The hmac_md5 function 
(RFC2104) is one example of a hashing function that is used in an embodiment of the invention to generate a response. 
[0102] The following packet format is used by network terminal 202 to send the response to authentication module 
240 according to one embodiment of the invention: 

code identifier length valueSize value userlD 

[0103] The code field is set to a value of "2" which indicates that the information packet contains a challenge 
response. The value field contains the challenge response (e.g., the result of a hashing function). The userlD field con- 
tains the user's userlD. 

[0104] If authentication module 240 determines (at step 510) that it received a response from network terminal 202, 
processing continues at step 512 to determine whether the identifier returned by network terminal 202 matches the 
identifier generated by authentication module 240. If so. processing continues at step 520 to examine the response 
returned by network terminal 202. 

[0105] At step 520. authentication module 240 determines whether the challenge response matches the response 
expected by authentication module 240. For example, authentication module 240 can generate a hash value using its 
identifier. PIN, secret and challenge values. If the hash value generated by authentication module 240 matches the 
challenge response generated by network terminal 202. authentication is partially successful. Authentication module 
240 also verifies that the interconnection network address of network terminal 202 and the user's userlD are valid. If the 
challenge response, interconnection network address and userlD are verified, authentication is successful. If not, 
authentication failed, 

[0106] If authentication is successful, processing continues at step 528 to send an N.AUTHENTICATE command. 
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The format of the command, according to an embodiment of the invention, is as follows: 



code identifier length 

5 [0107] The code field contains a value of "3" to indicate that the user was successfully authenticated. Processing con- 
tinues at step 530 to send rendering commands to networl< terminal 202 indicating that session manager 206 is con- 
necting the user to one of the user's sessions. At step 532, authentication manager 204 notifies session manager 206 
that the user is connected to the system via network terminal 202 and has been authenticated for certain specified ses- 
sions. Authentication manager 204 sends the interconnection network address of network terminal 202 and session 

10 manager 206's sessionID) to the server that is executing session manager 206 (i.e., the server identified in the session- 
Host field of the user's authentication database record) at step 532. 

[0108] If authentication failed, processing continues at step 522 to send an N_AUTHENTICATE command. Like a suc- 
cessful authentication, the N_AUTHENTICATE command includes a code field that indicates the status of the authen- 
tication process. A code value of "4" is used, for example to indicate that authentication failed. Processing continues at 
15 step 524 to send rendering commands to network terminal 202 indicating that the authentication failed and instructing 
the user to remove the smart card from card reader 216. 
[0109] The authentication process ends at step 526. 

[01 1 0] The process described with reference to Figures 5A-5B is one example of an authentication process. It should 
be apparent that other authentication techniques can be used with embodiments of the invention. In an alternate 
20 embodiment the user is not requested to enter a PIN. The user's card in card reader 216 is enough to authenticate the 
user. The userlD and secret value can be hashed with the identifier and the challenge received from authentication 
module 240 to generate a response to a challenge by authentication module 240. In this way, a user can attach to the 
user's services simply by inserting a card containing valid information into card reader 202. 

[0111] Further, it should be apparent that embodiments of the invention can be used wherein no authentication of a 
25 user is performed. For example, in a trusted or secure environment there may be no need to verify the authenticity of a 
user. In one or more embodiments of the invention, a user Is connected to a session only after being authenticated by 
authentication manager 204 or authentication modules 240. In such an embodiment, an authentication module 240 
may authenticate all users merely when presented with a token or when any name is typed into a login session, for 
example. Thus, the user only needs to provide an identification (e.g., userlD) or the terminal only needs to present a 
30 token. Consequently, if the user provides a valid userid (which may be designated as any id or any token), the user is 
given access to the session that is associated with the userlD (or token). Such tokens may be utilized to keep track of 
session to token mappings so that if a user switches terminals, the appropriate session to transmit to the terminal may 
be determined merely by checking the mapping. 

[0112] When the user disconnects from network terminal 202, authentication manager 204 or authentication modules 
35 240 is informed and informs session manager 206 of the disconnection. For example, when the user removes the smart 
card from card reader 216, card reader 21 6 informs network terminal 202. Network terminal 202 informs authentication 
manager 204 or authentication module 240 of the disconnection. Authentication manager 204 (which may have been 
informed by authentication module 240) informs session manager 206 that the user has disconnected from network ter- 
minal 202. Session manager 206 notifies each of the services in the user's session. 

40 

Challenge Routine 

[0113] The authentication process can include a challenge initiated by authentication module 240. Figure 6 provides 
a challenge routine process flow for handling a challenge according to an embodiment of the invention. The challenge 
45 routine executes on network terminal 202 in response to a challenge command received from authentication module 
240. 

[0114] At step 602, the key entry received from the user is read until a return or enter key is pressed. The key entry 
is translated to ASCII characters at step 604. At step 606, a hash function is used to generate a hash value, or challenge 
response, from the concatenation of the identifier, PIN, secret, and challenge values. The challenge response is sent 
50 to authentication module 240 at step 608. At step 610, network terminal 202 awaits a response from authentication 
module 240 or a timeout. If a response or a timeout occurs, the challenge routine ends at step 614. 

Network Terminal Initialization 

55 [0115] Network terminal 202 performs some initialization when it is first turned on. While a user is not using network 
terminal 202, network terminal 202 can be in a dormant state if it is powered on. A user can awaken network terminal 
202 from its dormant state using one of the techniques described herein, for example. It should be apparent that other 
techniques can be used to awaken network terminal. 
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- w for initializing network terminal 202 in respon^S a power up operation 

according to an embodiment of the invention. At step 302, a determination is made whether a power up operation has 
occurred. If not. processing continues to wait for a power up operation. At step 304. a request is generated by network 
terminal 202 to the network to test the network connection. At step 306. a determination is made whether a response 
IS received. If not. processing continues at step 310 to generate an en-or and processing continues at step 302 to await 
a power up operation. 

[0117] If it is determined, at step 306. that an answer Is received, processing continues at step 308 to send an 
acknowledge (an ACK) message and initialization of network terminal 202 can continue at step 402 of Figure 4A. 
[01 18] Figures 4A-4C provide a process flow according to an embodiment of the invention for initializing network ter- 
minal 202 in response to an awaken operation. Referring to Figure 4A. network terminal 202 waits for notification of the 
awaken operation. In an embodiment of the invention, the awaken operation is the insertion of a user's smart card in 
card reader 216. 

[01 19] If it is determined that a smart card Is inserted in card reader 216, processing continues at step 404 to send a 
request to obtain the interconnection network addresses of authentication manager 204 and network terminal 202. 
Alternatively, a user's smart card can be preprogrammed with the Interconnection network addresses. Network terminal 
202 can read the interconnection network addresses from the smart card via card reader 216, for example In one or 
more embodiments, a user's home server (or preferred server) Is preprogrammed Into a user's smart card Conse- 
quently If a user is working on a remote network, the user may still connect to the user's home server with the ability to 
utilize services associated with that server (that may not be available or available to the user on the remote network) 
[0120] At step 406. network terminal 202 awaits a response or a timeout. If a timeout occurs, processing continues 
at step 412 to determine whether the maximum number of tries has been exceeded. If the maximum number of tries 
has been exceeded, processing continues at step 410 to generate an error if the maximum number of tries has not 
been exceeded, processing continues at step 414 to increment the number of tries and processing continues at step 
404 to resend the request for the interconnection network addresses. 

[0121] When a response to the request is.received, processing continues at step 408 to send an ACK Processing 
continues at step 416 of Figure 4B. At step 416. network terminal 202 sends a startup request to authentication man- 
ager 204. At step 418. a retry time is set in which network terminal 202 waits for a response to the startup request At 
step 420, a variable is set to Indicate that network terminal 202 is waiting for a response to the startup request At step 
422. network terminal 202 waits for a response to the startup request. While network terminal 202 awaits a response 
authentication manager 204 may present the message to one or more authentication modules 240 to determine if one 
or more modules desires to take responsibility for the request. 

[0122] If it Is determined that a response is not received, processing continues at step 424 to determine whether the 
retry time as been exceeded. If not. processing continues at step 422 to wait for a response. If the retry time has been 
exceeded, processing continues at step 426 to determine whether the maximum number of tries has been exceeded 
If not, processing continues at step 428 to generate an error and return to step 416 to resend the startup request-lf not 
processing continues at step 430 to increment the number of tries and reset.the retry time. At step 432. the startup 
request is resent and processing continues at step 444 to determine whether the card has been removed from card 
reader 216. 

[0123] If it is determined, at step 422, that a response was received, processing continues at step 434 of Figure 4C 
At step 434, network terminal 202 examines the variable Initially set In step 420 to determine whether it is waiting for a 
response to the startup request. If so, processing continues at step 436 to determine whether the response is a chal- 
lenge message (e.g.. by an authentication module). If not, processing continues at step 424 to repeat the startup 
request if the maximum number of tries has not been exceeded. If it Is determined, at step 436. that a challenge mes- 
sage has been received, processing continues at step 438 to set the waiting_for_startup variable is set to no (i e "N") 
Processing continues at step 440 to process the .challenge request at steps 440 and 442. The challenge request can 
be handled as described above with reference to Figures 5A-5B and 6. for example. 

[0124] If it is determined, at step 434, that network terminal 202 is not waiting for a response to a startup request 
processing continues at steps 440 and 442 to handle the message (e.g.. rendering commands to display output gener- 
ated by service 234). » 

50 [0125] At step 444, a determination is made whether the user has removed the smart card from card reader 216 
When the user removes the card from card reader 216. network terminal 202 sends a disconnect message to authen- 
tication manager 204 (or the appropriate authentication module 240) at step 448. Network terminal 202 waits for an 
acknowledgment (ACK) message from authentication manager 204 (or authentication module 240) When the ACK 
message is received, network terminal 202 clears the screen, at step 450. and returns to step 402 to wait for another 

55 user to insert a smart card In card reader 216. 

[0126] If it is determined, at step 444, that the user has not removed the card from card reader 216. processing con- 
tinues at step 446 to determine whether network terminal is waiting for a response to its startup request. If so. process- 
ing continues at step 422 to determine whether a response has been received. If network terminal is not waiting for a 
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response from a startup request, processing continues at steps 440 and 442 to process any messages sent to network 
terminal 202. 

Message Format 

[0127] In an embodiment of the invention, a connection to network terminal 202 is established via a user datagram 
protocol (UDP) port. That is. packets are sent via a UDP connection and received at a destination UDP port. The des- 
tination UDP port uniquely identifies the connection. Packet length and checksum information are provided by the UDP 
header. Buffer size fits in an Ethernet Maximum Transfer Unit (MTU) with IP/UDP headers. Data is sent over the network 
in network byte order (big-endian). 

[0128] It should be apparent that other protocols can be used in place of UDP. For example, protocols such as an ATM 
AAL5 (AAL or ATM Adaptation Layer) can be used. 

[0129] Thus, a method and apparatus for session management and user authentication has been described. Partic- 
ular embodiments described herein are illustrative only and should not limit the present invention thereby The invention 
is defined by the claims and their full scope of equivalents. The features disclosed In the foregoing description, in the 
claims and/or in the accompanying drawings may, both separately and in any combination thereof, be material for real- 
ising the invention in diverse forms thereof 

Claims 

1. In a computer system, a method of controlling access to a session comprising: 

an authentication manager obtaining a request from a user for authentication; 
one or more authentication modules authenticating said user; and 

said one or more authentication modules notifying a session manager of said authentication. 

2. The method of claim 1 further comprising said one or more authentication modules revoking said user's authenti- 
cation. 

3. The method of claim 1 wherein said user is authenticated based on a challenge-response procedure. 

4. The method of claim 1 wherein said user is authenticated based on biometric data. 

5. The method of claim 1 wherein said user Is authenticated based on a smart card. 

6. The method of claim 1 wherein said user is authenticated for a specified period of time, 

7. The method of claim 1 wherein each of said one or more authentication modules is configured to authenticate a 
user using a different authentication mechanism. 

8. A system for controlling access to sessions comprising: 

a user; 

an authentication manager configured to obtain an authentication request from said user; 
one or more authentication modules configured to authenticate said user; and 

a session manager configured to obtain notification of authentication from said authentication modules. 

9. The system of claim 8 wherein said authentication modules are configured to revoke said user's authentication. 

10. The system of claim 8 wherein one of said authentication modules is configured to authenticate a user based on a 
challenge-response procedure. 

11. The system of claim 8 wherein one of said authentication modules is configured to authenticate a user based on 
biometric data. 

12. The system of claim 8 wherein one of said authentication modules is configured to authenticate a user based on a 
smart card. 
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13. The system of claim 8 wherein oneof said authentication modules is configured to authenHcate a user for a spec- 
ified period of time. 



14. The system of claim 8 wherein each of said one or more authentication modules is configured to authenticate a 
user using a different authentication mechanism. 

1 5. A computer program product comprising: 

a computer usable medium having computer readable program code embodied therein configured to control 
access to a session, said computer program product comprising: 

computer readable program code configured to cause an authentication manager to obtain a request from a 
user for authentication; 

computer readable program code configured to cause one or more authentication modules to authenticate said 
user: and 

computer readable program code configured to cause said one or more authentication modules to notify a ses- 
sion manager of said authentication. 

16. The computer program product of claim 15 further comprising computer readable program code configured to 
cause said one or more authentication modules to revoke said user's authentication. 

17. The computer program product of claim 15 wherein said authentication modules authenticate said user based on 
a challenge-response procedure. 

18. The computer program product of claim 15 wherein said authentication modules authenticate said user based on 
biometric data. 

19. The computer program product of claim 15 wherein said authentication modules authenticate said user based on 
a smart card. 



20. The computer program product of claim 15 wherein said authentication modules authenticate said user for a spec- 
ified period of time. 

21. The computer program product of claim 15 wherein each of said one or more authentication modules is configured 
to authenticate a user using a different authentication mechanism. 
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